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1 SPLIT TREE DATA STRUCTURE 
Technical Field of the Invention 

The present invention relates generally to document formatting and, in particular, 
to document formatting using input trees. More specifically, the present invention relates 
to a method and apparatus for creating a split tree by assigning marks to an input tree and 
for generating tree fragments from the split tree. The invention also relates to a computer 
program product including a computer readable medium having recorded thereon a 
computer program for creating the split tree by assigning marks to the input tree and for 
generating tree fragments from the split tree. 

Background Art 

High-level languages for document formatting exist in many forms, some of 
which accept as input a description of a document in the form of an input tree. An 
example of such an input tree is presented in Fig, 1. The input tree comprises two main 
types of elements, namely data elements and instruction elements, those elements in Fig. 
1 being indicated in Fig, 2. The data elements contain data to be formatted. Each data 
element can include text or images. Instruction elements contain information used by a 
document formatter to arrange the data elements on pages when producing an output. As 
seen in Fig. 3, the data elements form leaf nodes in the tree whereas the instruction 
elements form nodes. Further, nodes A and B are child nodes of node Cat(2), The left 
node, Node A in the example, is defined as the first child of node Cat(2), whereas the 
right node s Node B, is defined as the second child node Cat(2). 

Instruction elements can be thought of as operators that define the output 
positions of data elements. There are a number of instruction elements or operators 
available. Certain of the instruction elements, for example those defining text size, text 
spacing and the like, typically only have one child. 



504720US.doc 



-2- 

The other relevant instruction in Figs. 1 to 3 is "Cat( )", which performs vertical 
■concatenation. Each concatenation instruction places its left parameter (the first child) 
above its right parameter (second child). For example, Cat(2) would place the content of 
data element B below the content of data element A. 
5 As an input, data elements do not have an actual position. The actual position of 

the data elements is determined by the document formatter by evaluating the input tree. 
In the example of Fig. 1, the formatter, following the directions given by the instruction 
elements, determines that the result of the Cat(2) operator is placed above the result of the 
Cat(3) operator. The Cat(2) operator in turn places the content of data element A above 
10 data element B, and the Cat(3) operator places the content of data element C above data 
element D. The result is that data element A, B, C and D are stacked in that order. 

However, when the content of data elements are placed on a page in order to 
produce an output, it is sometimes found that the result is too big to fit onto one page. 
Therefore, placing the content data elements onto the page following the order specified, 
1 5 should the content of a next data element not fit into the space left on the present page, the 
remainder of the data elements are promoted to a next page. In the example presented in 
Fig. 1. if only the content of data elements A, B and C can fit onto page 1, then the 
content of data element D is promoted to page 2. The formatter also positions the data 
elements on the pages. The result of the evaluation of the input tree is shown in Fig. 4. 
20 To better explain the above, a galley and a galley target need to be defined. A 

galley is a part of the input tree, whereas a galley target is a placeholder for a galley. The 
galley is therefore not evaluated at a position in the input tree but rather at the point where 
ii is placed into the galley target. The galley target is a stretchable area on the output area 
with size 0 when no galley is targeted into it. When a galley is targeted into a galley 
25 target, the galley target stretches to accommodate for the incoming galley. The galley is 
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unable to stretch infinitely though. There are restrictions on the maximum size of each 
galley target. Should it happen that the galley target reaches its maximum size before the 
galley is exhausted, a new galley target is found for the remainder of the content of the 
galley and the process of accommodating the remainder of the galley into the new target 
5 is continued. 

Placing a galley into a series of galley targets involves splitting the input tree 
into fragments, each fragment filling its target. Fig. 5 shows another example of a galley 
in the form of an input tree 500. It is assumed that the galley in the example of Fig. 5 is 
targeted into a sequence of targets, with only data elements A and B fitting into the first 
10 galley target in the sequence by taking all the available space defined by the restrictions 
on the first galley target. The rest of the galley is promoted to the following galley target 
in the sequence. 

Figs 6A and 6B show the result after a portion of the galley of Fig.5 is placed 
into the sequence of galley targets. The original input tree 500 shown in Fig. 5 is split 
15 into the two tree fragments 510 and 520 respectively. The first fragment 510, shown in 
Fig. 6A, is placed into the first galley target. The remainder of the galley which now 
resides in the second tree fragment 520, shown in Fig. 6B, is waiting to be placed into the 
following galley targets. Thus, the original galley was split into two separate smaller 
trees. 

20 The arrangement described above is used in batch text formatters which produce 

an output from an input tree. However, this arrangement suffers from the disadvantage 
that once the galley is Split into smaller trees, it is hard to relate the fragmented trees back 
to their original galley tree. This is for example necessary whenever the order or contents 
of the data elements are changed, thus preventing interactive formatting. 
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Disclosure of the Invention 

It is an object of the present invention to substantially overcome, or at least 
ameliorate, one or more disadvantages of existing arrangements. 

According to a first aspect of the invention, there is provided a method of 
5 creating a split tree for representing an input tree and at least one tree fragment obtained 
by splitting the input tree, wherein the input tree comprises a plurality of nodes, said 
method comprising the steps of: 

determining which of the plurality of nodes fit into each galley target; and 
marking the nodes that fit into each galley target with a mark specific to the 
10 galley target so as to create the split tree in which each tree fragment is identified by 
respective mark. 

According to a second aspect of the invention, there is provided a method of 
splitting a split tree into at least one tree fragment, wherein each of the tree fragment is 
associated with a mark specific to the tree fragment and the split tree comprises at least 
15 one node marked with the mark, said method comprising the steps of: 
identifying the at least one node marked with the mark; and 
creating each tree fragment from the nodes marked with the mark specific to 
the tree fragment 

According to a third aspect of the invention, there is provided an apparatus for 
20 creating a split tree for representing an input tree and at least one tree fragment obtained 
by splitting the input tree, wherein the input tree comprises a plurality of nodes, said 
apparatus comprising: 

determining means for determining which of the plurality of nodes fit into each 
galley target; and 
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marking means for marking the nodes that fit into each galley target with a 
marie specific to the galley target 'SO as to create the split tree in which each tree fragment 
is identified by respective mark. 

According to a fourth aspect of the invention there is provided an apparatus for 
5 splitting a split tree into at least one tree fragment, wherein each of the tree fragment is 
associated with a mark specific to the tree fragment and the split tree comprises at least 
one node marked with the mark, said apparatus comprising: 

identification means for identifying the at least one node marked with the 
mark; and 

10 creating means for creating each tree fragment from the nodes marked with the 

mark specific to the tree fragment. 

According to a fifth aspect of the invention, there is provided a computer 
program product including a computer readable medium incorporating a computer 
program for creating a split tree for representing an input tree and at least one tree 
15 fragment obtained by splitting the input tree, wherein the input tree comprises a plurality 
of nodes, said computer program product comprising: 

means for determining which of the plurality of nodes fit into each galley 
target; and 

means for marking the nodes that fit into each galley target with a mark 
20 specific to the galley target so as to create the split tree in which each tree fragment is 
identified by respective mark. 

According to a sixth aspect of the invention, there is provided a computer 
program product including a computer readable medium incorporating a computer 
program for splitting a split tree into at least one tree fragment, wherein each of the tree 
25 fragment is associated with a mark specific to the tree fragment and the split tree 
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comprises at least one node marked with the mark, said computer program product 
comprising: 

means for identifying the at least one node marked with the mark; and 
means for creating each tree fragment from the nodes marked with the mark 
5 specific to the tree fragment. 

Brief Description of the Drawings 
A preferred embodiment of the present invention will now be described with 
reference to the drawings, in which: 

Fig. 1 is an example of an input tree; 
1 0 Fig- 2 illustrates types of elements in the input tree; 

Fig. 3 illustrates nodes, leaf nodes and edges in the input tree; 
Fig. 4 shows the result of evaluation of the input tree; 
Fig. 5 shows an original galley before splitting; 

Figs. 6A and 6B show the result of splitting the original galley of Fig. 5 into 
1 5 smaller fragments; 

Fig, 7 shows a split tree; 

Fig. 8 shows the split tree of Fig. 7 after changes; 
Fig. 9 is a flow diagram of a method of generating a split tree; 
Fig. 10 is a flow diagram of a method of creating tree fragments from a split tree; 
20 Fi S* 11 is a flow diagram of a method of finding a next node; 

Fig. 12 is a flow diagram of a method of building a tree fragment; 
Fig. 13 is a schematic block diagram of a general purpose computer upon which 
the preferred embodiment of the present invention can be practised. 

Detailed Description including Best Mode 
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In the preferred embodiment of the present invention, the actual splitting of the 
galley tree, ass duscussed above, does not take place. This allows the structure of the 
galley to remain intact. The advantage of preserving the original structure of the galley 
tree is that it allows interactive formatting. For instance, it makes it easier to re-send the 
5 galley into its targets after the galley or its target has been modified. The re-sending of 
the galley usually involves moving the splitting boundary between the tree fragments. 

The preferred embodiment represents a galley using a Split Tree data structure. 
The Split Tree data structure allows a split tree to represent both the galley tree and the 
fragments of the galley tree that are the result of splitting the galley. The advantage is 
10 that instead of actually splitting the galley tree, marks are added to the tree. The marks 
allow an algorithm operating on the split tree to interpret the split tree in the same way as 
tree fragments would be interpreted. 

The split tree 550 corresponding to the two galley fragments 510 and 520 in the 
above example of Figs. 6 A and 6B is presented in Fig, 7. The fragment of the galley tree 
15 that is placed into the first galley target is marked with markers '1\ The fragment that 
did not fit into the first galley target is marked with marker '0\ The marker *0' is a 
special marker that marks nodes that are still waiting to be placed into galley targets. 

The split tree data structure allows each tree fragment in the split tree 550 to be 
marked with a unique mark. In the preferred embodiment, integers are used as marks. 
20 Fig. 8 shows another example of a split tree 560. The galley of Fig. 7 is placed 

into a sequence of galley targets. For this example however, the three data elements A, B 
as well as C can fit into the first galley target. This change can be a result of a change in 
the available space for the first galley target, data elements A, B and/or C. 
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Each 1 node in the split tree can have two, one or no children. The nodes that have 
do children are also called leaf nodes. The criteria for interpreting the split tree are as 
follows: 

• If a node is marked with a marker 'n% the whole subtree attached to that node belongs 
5 to the *n* fragment. 

• If both the left and right subtrees of a node contain nodes marked with 'n\ the node 
belongs to the s n' fragment. This criterion has further implications. If a node does 
not contain nodes marked with the same marker in its left and right subtrees, then 
such a node does not belong to any fragment and is referred to as an alienated node. 

10 Any marked node, therefore a node that is not an alienated node, belongs to one tree 

fragment only. 

• If a node has only one child and the child subtree has a node marked with *n% then the 
node belongs to the 'n' fragment 

A method 300 of adding marks to a split tree is presented in Fig, 9. The purpose 
15 of the method 300 is to place the galley tree into its galley targets. In particular, it adds 
marks to the galley tree, the marks defining which parts of the galley tree are placed into 
which galley target and returns the space remaining in that galley target. 

In step 301 the method 300, named GST, accepts three input parameters, namely. 

• node - The subtree defined by 'node 7 that is currently being pushed into a galley 
20 target; 

• available__space - The space available in the galley target for 'node'; and 

• mark - The mark used to mark all nodes that are pushed into a galley target 
Step 303 determines whether 'node' is already marked. If 'node' is marked, it 

means that it has already been placed into some other target and the subtree defined by 
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6 node 1 is therefore ignored. The method 300 is then terminated in step 304 after returning 
*available_$paete\ In this case *available_space' has not changed. 

For unmarked nodes, the method 300 proceeds to step 306. Step 306 determines 
whether the subtree defined by 'node' can fit into i available_space\ If that subtree can fit 
5 into £ available_space > , then 'node', together with all the other nodes in that subtree, are 
marked with 'mark' in step 308. As £ node' uses up some of 'available_space% 
*available_space* is decreased in step 309 by the size of the subtree defined by 'node*. 
The value of < available_space 5 is returned. 

However, if in step 306, the subtree defined by 'node' cannot fit into 
10 r available_space\ then the method 300 continues by trying to split the subtree into 
smaller subtrees. In order to do so, in step 313 which follows, the method 300 verifies 
whether 'node' is a leaf element (thus have no children nodes) or has been defined as not 
splitable. In such cases, 'node 7 cannot be placed into the target, nor can it be split thereby 
enabling the smaller subtree of 'node' to fit into the target. Tn step 314, the data elements 
15 represented by 'node' is discarded and 'node' is marked with a special discarded mark 
and the method 300 is terminated in step 328 where the value of £ available_space' is 
returned. 

If 'node* is determined to be splitable in step 313, step 317 determines whether 
'node' has only one child. If 'node' has only one child, then step 3 IS recursively calls the 
20 method 300 with the child node as 'node' . 

Since leave nodes were filtered out by step 313 and nodes with only one child by 
step 317, only when 'node' has two children is step 319 performed, where the method 300 
is recursively called with a first child of 'node 5 as 'node'. Then, if step 324 determines 
that there is space left in the target, the method 300 is called again in step 325 with a 
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second child of 'node' as <node\ The method 300 terminates by returning the available 
space in the galley target in step 328. 

The method 300 is repeated with the next galley target, until all the data elements 
are placed. The result is that galleys in the input tree are now converted into split trees by 
5 marking the nodes. 

Fig, 10 presents a method 40 for generating tree fragments from a split tree. The 
method 40 calls procedures 50 and 70, presented in Figs 11 and 12 respectively. These 
procedures 50 and 70 are discussed first. 

Procedure 50 is a recursive procedure that finds a next node belonging to a tree 
10 fragment in a split tree. This tree fragment is one of the tree fragments previously defined 
by marking the input tree, thereby creating the split tree. The tree fragment is accordingly 
specified by one of the marks used in the split tree. The procedure 50 terminates once a 
appropriately marked node is found. 

Procedure 50 commences with step 41, which accepts two input parameters, 

1 5 namely: 

• startNode - The node defining the subtree wherein the marked node is searched 
for; and 

• mark - The mark that marks the node being searched for. 

Procedure 50 proceeds to step 43 where it is determined whether 'startNode 5 is 
20 marked with 'mark'. If so, this is the node that is searched for, and the procedure 50 
terminates in step 44 by returning 'startNode* to its calling method or procedure. 

If the 'startNode' is not marked with *mark\ step 46 follows which determines 
whether startNode is marked with another mark, such indicates that 'startNode* and all 
the other nodes in its subtree are marked with a mark other than 'mark 7 . It is therefore not 
25 possible for any node marked with 'mark' to be found in the subtree under review, and 
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the procedure 50 terminates in step 47 by returning NULL to its calling method or 
procedure. 

Therefore, only an unmarked node proceeds to step 48 from where, if step 48 
determines that 'startNode' has only one child, then the procedure 50 is called in step 49 
5 with the child node as 'startNode 5 . 

Step 51 determines whether step 49 (calling procedure 50 with the child node) 
returned with NULL. If NULL was returned, neither 'startNode* nor any of the nodes in 
the subtree belong to the tree fragment marked with 'mark' and procedure 50 terminates 
after returning NULL in step 53- However, if step 49 did not return a NULL, the 
10 'startNode' belongs to the tree fragment marked with 'mark'. The procedure 50 returns 
'startNode' and terminates in step 52. 

Referring again to step 48, only unmarked nodes with two children proceed to 
step 54 from where procedure 50 is called with the first child as 'startNode'. It is 
followed by step 55 from where procedure 50 is called with the second child as 
15 'startNode*. 

Step 56 determines whether calling procedure 50 with the first child as 
"startNode' returned NULL. If so, step 56 determines whether calling procedure 50 with 
the second child as "startNode' returned a NULL. If NULLs were returned for both the 
first child and the second child, the calling procedure 50 terminates after also returning 

20 NULL in step 58, Thus 'mark' has not been found in any one of the children. If 'mark' 
has been found in one of the children, procedure 50 will terminate after returning that 
child node to the calling method or procedure in step 60 or step 62. The remaining 
alternative is that both children were marked with 'mark' in which case the criteria in 
both step 56 and step 61 are not met. The procedure 50 terminates by returning 

25 'startNode 1 , being the parent of the two children, at step 63. 
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Referrmg to Fig. 12, procedure 70 for generating nodes of a tree fragment is 
shown. Procedure 70 is invoked recursively to find all the nodes of a tree fragment in a 
split tree and to generate a whole tree fragment. The tree fragment is defined by a 
specific mark. 

5 In step 75, procedure 70 accepts three parameters, namely: 

• node - A node of a tree fragment; 

• mark - The mark that marks the nodes belonging to a tree fragment in a split tree; 
and 

• perform - A function that is invoked for each node belonging to the tree fragment 
10 defined by 'mark*. 

If step 76 determines that 'node' is equal to NULL, there are no nodes in that 
subtree marked with 'mark* and step 77 returns procedure 70 to its calling method or 
procedure. 

However, if c node' is not determined to be equal to NULL in step 76, then step 
15 SO invokes the 'perform' function. This caller-defined function performs required 
operations on the nodes of the 7 mark' tree fragment. This may include saving the result to 
a file, modifying the attributes of the nodes or displaying the result in a tree form on a 
user interface. 

If step 82 determines that 'node' has no children ie. a leave node, the procedure 
20 70 terminates in step 77 and returns to its calling procedure or method. If step S4 
determines that 'node* has only one child, the child subtree is searched in step 86 to find 
the next node belonging to the tree fragment presently being generated. This is done by 
calling procedure 50 with the node of the child as 'startNode'. After finding the next 
node marked with 'mark', procedure 70 is called again in step 88 with this found next 
25 node as 'node'. Procedure 70 calling itself recursively will continue adding new child 
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nodes to the generated tree until there are no more nodes in the subtree defined by the 
child node marked with mark. 

If 'node' has two children the procedure 70 will proceed from step 84 to step 90 
where, the children subtrees are treated in the same way as a single child, in that steps 90 
5 and 91 will find all the nodes in the subtree defined by the first child and generate a tree 
until there are no more nodes in the subtree defined by the first child node marked with 
mark. Steps 94 and 95 repeat identical steps for the second child. The procedure 70 
terminates in step 77. 

In the preferred embodiment of the invention, method 40, illustrated in Fig. 10, 
1 0 starts in step 41 by accepting three parameters, namely: 

• spHt_tree - the root node of the split tree; 

• mark - the mark that marks the nodes belonging to a tree fragment in a split tree; 
and 

• perform - The function that is invoked for each node belonging to the 'mark' tree 
15 fragment. 

Method 40 proceeds to step 43 where a root node of a tree fragment in a split tree 
is found. This is performed by calling procedure 50, which will return the first node 
found with 'mark 7 as its marking. Procedure 50 returns NULL if the split tree does not 
contain a tree fragment marked with 'mark\ 

20 Having established the root node in step 43, step 45 calls procedure 70 passing 

the root node as 'node'. As discussed above, procedure 70 is a recursive procedure for 
iterating over all the nodes of the tree fragment in the split tree, finding the correctly 
marked nodes and creating the required tree fragment. Method 40 terminates in step 46. 

The method 30 of marking an input tree to create a split tree and method 40 of 

25 creating tree fragments from the split tree, are preferably practiced using a conventional 
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general-purpose computer system 200, such as that shown in Fig. 13 wherein the 
processes of Figs. 9 to 12 may be implemented as software, such as an application 
program executing within the computer system 200. In particular, the steps of methods 
30 and 40 are effected by instructions in the software that are carried out by the computer. 

5 The software may be stored in a computer readable medium, including the storage 
devices described below, for example. The software is loaded into the computer from the 
computer readable medium, and then executed by the computer. A computer readable 
medium having such software or computer program recorded on it is a computer program 
product. The use of the computer program product in the computer preferably effects an 

10 advantageous apparatus for 30 for marking an input tree to create a split tree and for 
creating tree fragments from the split tree in accordance with the embodiments of the 
invention. 

The computer system 200 comprises a computer module 202, input devices such 
as a keyboard 210 and mouse 212 5 output devices including a printer 208 and a display 
15 device 104. 

The computer module 202 typically includes at least one processor unit 214, a 
memory unit 218, for example formed from semiconductor random access memory 
(RAM) and read only memory (ROM), input/output (I/O) interfaces including a video 
interface 217, and an I/O interface 216 for the keyboard 210 and mouse 212. A storage 

20 device 224 is provided and typically includes a hard disk drive 226 and a floppy disk 
drive 228. A magnetic tape drive (not illustrated) may also be used. A CD-ROM 
drive 220 is typically provided as a non-volatile source of data. The components 214 
to 228 of the computer module 202, typically communicate via an interconnected bus 230 
and in a maimer which results in a conventional mode of operation of the computer 

25 system 200 known to those in the relevant art. Examples of computers on which the 
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embodiments can be practised include IBM-PC's and compatibles, Sun Sparcstations or 
alike computer systems evolved therefrom. 

Typically, the application program of the preferred embodiment is resident on 
the hard disk drive 226 and read and controlled in its execution by the processor 214. 

5 Intermediate storage of the program may be accomplished using the semiconductor 
memory 218, possibly in concert with the hard disk drive 226. In some instances, the 
application program may be supplied to the user encoded on a CD-ROM or floppy disk 
and read via the corresponding drive 220 or 228. Still further, the software can also be 
loaded into the computer system 200 from other computer readable medium including 

1 0 magnetic tape, a ROM or integrated circuit a magneto-optical disk, a radio or infra-red 
transmission channel between the computer module 202 and another device, a computer 
readable card such as a PCMCIA card, and the Internet and Intranets including email 
transmissions and information recorded on websites and the like. The foregoing is merely 
exemplary of relevant computer readable mediums. Other computer readable mediums 

1 5 may be practiced without departing from the scope and spirit of the invention. 

The methods of marking an input tree to create a split tree and of creating tree 
fragments from the split tree may alternatively be implemented in dedicated hardware 
such as one or more integrated circuits performing the functions or sub functions of 
processes 30 and/or 40. 

20 The foregoing preferred methods describe only one embodiment of the present 

invention, and modifications, can be made thereto without departing from the scope of the 
present invention as defined in the appended claims. 
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I claim; 

1. A method of creating a split tree for representing an input tree and at 
least one tree fragment obtained by splitting the input tree, wherein the input tree 

5 comprises a plurality of nodes, said method comprising the steps of: 

determining which of the plurality of nodes fit into each galley target; and 
marking the nodes that fit into each galley target with a mark specific to the 

galley target so as to create the split tree in which each tree fragment is identified by 

respective mark. 

10 

2. The method according to claim 1, wherein said determining step 
comprising the steps of: 

setting one of the plurality of nodes as a current node for a galley target; 

checking whether the current node has already been marked; 
15 comparing the size of the current node with available space in the galley target 

if the current node has not marked; and 

deciding that the current node fits into the galley target if the size of the current 
node is not greater than the available space. 

20 3. The method according to claim 2, further comprising the step of 

updating the available space by decreasing the size of the current node if it is determined 
that the current node fits into the galley target. 

4, The method according to claim 2 5 further comprising the steps of: 
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determining whether the current node has at least one child node if the size of 
the current node is greater than the available space; 

setting one of the child node as the new current node if the current node has at 
least one child node; and 
5 recursively executing said checking, comparing, and deciding steps with 

respect to the new current node. 

5. The method according to claim 4, wherein in said step of setting the 
new current node, a first node and a second node are set as the new current node, 

10 sequentially, when the current node has two children nodes. 

6. The method according to claim 4, wherein in said marking step, the 
current node is marked with a special mark if the size of the current node is greater than 
the available space and that the current node has no children nodes. 

15 

7. A method of splitting a split tree into at least one tree fragment, wherein 
each of the tree fragment is associated with a mark specific to the tree fragment and the 
split tree comprises at least one node marked with the mark, said method comprising the 
steps of: 

20 identifying the at least one node marked with the mark; and 

creating each tree fragment from the nodes marked with the mark specific to 
the tree fragment. 
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8. The method according to claim 7, wherein said identifying step 
comprising the step of searching the at least one node in the split tree for the node with 
the mark specific to the tree fragment. 

9. The method according to claim 8, wherein said searching step 
comprising the steps of; 

setting one of the at least one node as a start node; 

checking whether the start node is marked with the mark specific to the tree 
fragment; and 

completing the search if the start node is marked with the mark specific to the 
tree fragment 

10. The method according to claim 9 5 further comprising the steps of: 
checking whether the start node has already been marked if the start node is not 

marked with the mark specific to the tree fragment; 

determining whether the start node has at least one child node if the start node 
has not been marked; 

setting one of the child node in place of the start node if the start node has at 
least one child node; and 

recursively executing said searching step with respect to the set child node. 

1 1 . The method according to claim 1 0, wherein in said step of setting one 
of the child node, a first node and a second node are set sequentially, when the start node 
has two children nodes. 
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12." The method according to claim 7, wherein said creating step comprising 
the step of performing a predetermined function -on the nodes marked -with the mark 
specific to the tree fragment. 

5 13. Apparatus for creating a split tree for representing an input tree and at 

least one tree fragment obtained by splitting the input tree, wherein the input tree 
comprises a plurality of nodes, said apparatus comprising: 

determining means for determining which of the plurality of nodes fit into each 
galley target; and 

10 marking means for marking the nodes that fit into each galley target with a 

mark specific to the galley target so as to create the split tree in which each tree fragment 
is identified by respective mark. 

14. The apparatus according to claim 13, wherein said determining means 
1 5 comprising: 

setting means for setting one of the plurality of nodes as a current node for a 
galley target; 

checking means for checking whether the current node has already been 

marked; 

20 comparing means for comparing the size of the current node with available 

space in the galley target if the current node has not marked; and 

deciding means for deciding that the current node fits into the galley target if 
the size of the current node is not greater than the available space. 
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15. The apparatus according to claim 14, further comprising updating 
means for updating the available space by decreasing the size of the current node if it is 
determined that the current node fits into the galley target, 

5 16. The apparatus according to claim 14, further comprising: 

child node determining means for determining whether the current node has at 
least one child node if the size of the current node is greater than the available space; 

second setting means for setting one of the child node as the new current node 
if the current node has at least one child node; and 
1 0 controlling means for recursively executing checking by said checking means, 

comparing by said comparing means, and deciding by said deciding means with respect 
to the new current node. 

17. The apparatus according to claim 16, wherein said second setting means 
15 sets a first node and a second node as the new current node, sequentially, when the 

current node has two children nodes. 

18. The apparatus according to claim 16, wherein said marking means 
marks the current node with a special mark if the size of the current node is greater than 

20 the available space and that the current node has no children nodes. 

19. Apparatus for splitting a split tree into at least one tree fragment, 
wherein each of the tree fragment is associated with a mark specific to the tree fragment 
and the split tree comprises at least one node marked with the mark, said apparatus 

25 comprising: 
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identification means for identifying the at least one node marked with the 
mark; and 

creating means for creating each tree fragment from the nodes marked with the 
mark specific to the tree fragment. 

20. The apparatus according to claim 19, wherein said identification means 
comprises search means for searching the at least one node in the split tree for the node 
with the mark specific to the tree fragment 



10 21. The apparatus according to claim 20, wherein said search means 

comprising: 

setting means for setting one of the at least one node as a start node; 
checking means for checking whether the start node is marked with the mark 
specific to the tree fragment; and 
1 5 completing means for completing the search if the start node is marked with 

the mark specific to the tree fragment. 



22, The apparatus according to claim 21, further comprising: 

mark checking means for checking whether the start node has already marked 
20 if the start node is not marked with the mark specific to the tree fragment; 

child node determining means for determining whether the start node has at 
least one child node if the start node has not been marked; 

second setting means for setting one of the child node in place of the start node 
if the start node has at least one child node; and 
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controlling means for recursively executing search by said search means with 
respect to the set child node. 



23 . The apparatus according to claim 22 s wherein said second setting means 
5 sets a first node and a second node sequentially, when the start node has two children 

nodes. 

24. The apparatus according to claim 19, wherein said creating means 
comprising function means for performing a predetermined function on the nodes 

10 marked with the mark specific to the tree fragment. 

25. A computer program product including a computer readable medium 
incorporating a computer program for creating a split tree for representing an input tree 
and at least one tree fragment obtained by splitting the input tree, wherein the input tree 

1 5 comprises a plurality of nodes, said computer program product comprising; 

means for determining which of the plurality of nodes fit into each galley 
target; and 

means for marking the nodes that fit into each galley target with a mark 
specific to the galley target so as to create the split tree in which each tree fragment is 
20 identifi ed by respective mark. 

26* A computer program product including a computer readable medium 
incorporating a computer program for splitting a split tree into at least one tree fragment, 
wherein each of the tree fragment is associated with a mark specific to the tree fragment 
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> 

and the split tree comprises at least one node marked with the mark, said computer 

program product comprising: 

means for identifying the at least one node marked with the mark; and 

means for creating each tree fragment from the nodes marked with the mark 

specific to the tree fragment. 
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. , SPLIT TREE DATA STRUCTURE 

ABSTRACT 

The present invention relates to document formatting using input trees. A method (30) 
and apparatus (200) for creating a split tree is provided, Marks are assigned to an input 
tree, removing the need to split the input tree and allowing the input tree structure to 
remain intact. The advantage of preserving the original structure of the input tree is that it 
allows interactive formatting. A method (40) of creating tree fragments from the split tree 
is also provided. 
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